package com.fowo.api.model.inventory.flows;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.fowo.api.common.validator.*;
import io.swagger.v3.oas.annotations.media.Schema;
import javax.validation.constraints.*;
import lombok.Getter;
import lombok.Setter;

/**
 * 库存流水 预览导入辅助模型(全字段为文本类型)
 * @author yl_ls
 */
@Getter
@Setter
public class InventoryFlowsImportPo {

  /** 操作时间 */
  @ExcelProperty("操作时间")
  @DateTimeString(message = "操作时间不是有效的时间日期格式")
  private String operateTime;

  /** 类型 */
  @ExcelProperty("类型")
  @Size(max = 50, message = "类型长度不能超过50")
  private String documentType;

  /** 单据号 */
  @ExcelProperty("单据号")
  @Size(max = 50, message = "单据号长度不能超过50")
  private String countnum;

  /** 关联单据号 */
  @ExcelProperty("关联单据号")
  @Size(max = 50, message = "关联单据号长度不能超过50")
  private String formNum;

  /** 品名 */
  @ExcelProperty("品名")
  @Size(max = 500, message = "品名长度不能超过500")
  private String itemIdName;

  @ExcelIgnore
  @Schema(title = "品名")
  private String itemId;

  /** SKU */
  @ExcelProperty("SKU")
  @Size(max = 50, message = "SKU长度不能超过50")
  private String sku;

  /** 店铺 */
  @ExcelProperty("店铺")
  @Size(max = 50, message = "店铺长度不能超过50")
  private String shopIdShopName;

  @ExcelIgnore
  @Schema(title = "店铺")
  private String shopId;

  /** FNSKU */
  @ExcelProperty("FNSKU")
  @Size(max = 50, message = "FNSKU长度不能超过50")
  private String fnSku;

  /** 产品类型 */
  @ExcelProperty("产品类型")
  @Size(max = 50, message = "产品类型长度不能超过50")
  private String itemType;

  /** 仓库 */
  @ExcelProperty("仓库")
  @Size(max = 50, message = "仓库长度不能超过50")
  private String stockIdName;

  @ExcelIgnore
  @Schema(title = "仓库")
  private String stockId;

  /** 可用量 */
  @ExcelProperty("可用量")
  @LongString(message = "可用量数值格式不正确", label = "可用量")
  private String stockQty;

  /** 次品量 */
  @ExcelProperty("次品量")
  @LongString(message = "次品量数值格式不正确", label = "次品量")
  private String defectQty;

  /** 待检待上架量 */
  @ExcelProperty("待检待上架量")
  @DecimalString(message = "待检待上架量小数格式不正确", label = "待检待上架量")
  private String inspectedQty;

  /** 可用锁定量 */
  @ExcelProperty("可用锁定量")
  @DecimalString(message = "可用锁定量小数格式不正确", label = "可用锁定量")
  private String lockQty;

  /** 次品锁定量 */
  @ExcelProperty("次品锁定量")
  @DecimalString(message = "次品锁定量小数格式不正确", label = "次品锁定量")
  private String rejectLockQty;

  /** 可用在途量 */
  @ExcelProperty("可用在途量")
  @DecimalString(message = "可用在途量小数格式不正确", label = "可用在途量")
  private String wayQty;

  /** 次品在途量 */
  @ExcelProperty("次品在途量")
  @DecimalString(message = "次品在途量小数格式不正确", label = "次品在途量")
  private String rejectWayQty;

  /** 采购单价 */
  @ExcelProperty("采购单价")
  @DecimalString(message = "采购单价小数格式不正确", label = "采购单价")
  private String purchasePrice;

  /** 单位费用 */
  @ExcelProperty("单位费用")
  @DecimalString(message = "单位费用小数格式不正确", label = "单位费用")
  private String unitCosts;

  /** 单位头程 */
  @ExcelProperty("单位头程")
  @DecimalString(message = "单位头程小数格式不正确", label = "单位头程")
  private String unitHeadStroke;

  /** 单位库存成本 */
  @ExcelProperty("单位库存成本")
  @DecimalString(message = "单位库存成本小数格式不正确", label = "单位库存成本")
  private String unitInventoryCost;

  /** 货值 */
  @ExcelProperty("货值")
  @DecimalString(message = "货值小数格式不正确", label = "货值")
  private String goodsValue;

  /** 费用 */
  @ExcelProperty("费用")
  @DecimalString(message = "费用小数格式不正确", label = "费用")
  private String expenses;

  /** 头程 */
  @ExcelProperty("头程")
  @DecimalString(message = "头程小数格式不正确", label = "头程")
  private String headStroke;

  /** 库存成本 */
  @ExcelProperty("库存成本")
  @DecimalString(message = "库存成本小数格式不正确", label = "库存成本")
  private String inventoryCost;

  /** 操作人 */
  @ExcelProperty("操作人")
  @LongString(message = "操作人数值格式不正确", label = "操作人")
  private String operator;

  /** 项目内码 */
  @ExcelProperty("项目内码")
  @LongString(message = "项目内码数值格式不正确", label = "项目内码")
  private String projectId;

  /** 备注 */
  @ExcelProperty("备注")
  @Size(max = 50, message = "备注长度不能超过50")
  private String remark;

  /** 次品结存量 */
  @ExcelProperty("次品结存量")
  @LongString(message = "次品结存量数值格式不正确", label = "次品结存量")
  private String inventoryOfDefectiveGoods;

  /** 次品锁定结存量 */
  @ExcelProperty("次品锁定结存量")
  @LongString(
    message = "次品锁定结存量数值格式不正确",
    label = "次品锁定结存量"
  )
  private String lockStockGoods;

  /** 可用锁定量 */
  @ExcelProperty("可用锁定量")
  @LongString(message = "可用锁定量数值格式不正确", label = "可用锁定量")
  private String locksAvailableAmount;

  /** 可用锁定结存量 */
  @ExcelProperty("可用锁定结存量")
  @LongString(
    message = "可用锁定结存量数值格式不正确",
    label = "可用锁定结存量"
  )
  private String numberOfAvailableLock;

  /** 操作业务名称 */
  @ExcelProperty("操作业务名称")
  @Size(max = 50, message = "操作业务名称长度不能超过50")
  private String operate;

  /** 关联唯一操作键 */
  @ExcelProperty("关联唯一操作键")
  @Size(max = 50, message = "关联唯一操作键长度不能超过50")
  private String operateKey;

  /** 所属库存明细 */
  @ExcelProperty("所属库存明细")
  @LongString(message = "所属库存明细数值格式不正确", label = "所属库存明细")
  private String parentInventoryDetails;

  /** 待检待上架量 */
  @ExcelProperty("待检待上架量")
  @LongString(message = "待检待上架量数值格式不正确", label = "待检待上架量")
  private String inspected;

  /** 未知 */
  @ExcelProperty("未知")
  @DecimalString(message = "未知小数格式不正确", label = "未知")
  private String rejectLockGty;

  /** 库存金额 */
  @ExcelProperty("库存金额")
  @DecimalString(message = "库存金额小数格式不正确", label = "库存金额")
  private String stockAmount;

  /** 暂存数量 */
  @ExcelProperty("暂存数量")
  @DecimalString(message = "暂存数量小数格式不正确", label = "暂存数量")
  private String storageQty;

  /** 变动目标类型 */
  @ExcelProperty("变动目标类型")
  @Size(max = 10, message = "变动目标类型长度不能超过10")
  private String toType;

  /** 可用在途量 */
  @ExcelProperty("可用在途量")
  @LongString(message = "可用在途量数值格式不正确", label = "可用在途量")
  private String availableCapacityInTransit;

  /** 可用结存量 */
  @ExcelProperty("可用结存量")
  @LongString(message = "可用结存量数值格式不正确", label = "可用结存量")
  private String availableInventory;

  /** 可用在途结存量 */
  @ExcelProperty("可用在途结存量")
  @LongString(
    message = "可用在途结存量数值格式不正确",
    label = "可用在途结存量"
  )
  private String availableTransitInventory;

  /** 批号 */
  @ExcelProperty("批号")
  @LongString(message = "批号数值格式不正确", label = "批号")
  private String batchNo;

  /** 业务时间 */
  @ExcelProperty("业务时间")
  @DateTimeString(message = "业务时间不是有效的时间日期格式")
  private String businessTime;

  /** 变动残次库存 */
  @ExcelProperty("变动残次库存")
  @DecimalString(message = "变动残次库存小数格式不正确", label = "变动残次库存")
  private String changeDefectQty;

  /** 变动陈列库存 */
  @ExcelProperty("变动陈列库存")
  @DecimalString(message = "变动陈列库存小数格式不正确", label = "变动陈列库存")
  private String changeDisplayQty;

  /** 待检数量变更 */
  @ExcelProperty("待检数量变更")
  @DecimalString(message = "待检数量变更小数格式不正确", label = "待检数量变更")
  private String changeInspectedQty;

  /** 变动锁库库存 */
  @ExcelProperty("变动锁库库存")
  @DecimalString(message = "变动锁库库存小数格式不正确", label = "变动锁库库存")
  private String changeLockQty;

  /** 次品锁定变更数量 */
  @ExcelProperty("次品锁定变更数量")
  @DecimalString(
    message = "次品锁定变更数量小数格式不正确",
    label = "次品锁定变更数量"
  )
  private String changeRejectLockQty;

  /** 次品在途数量变更 */
  @ExcelProperty("次品在途数量变更")
  @DecimalString(
    message = "次品在途数量变更小数格式不正确",
    label = "次品在途数量变更"
  )
  private String changeRejectWayQty;

  /** 变动库存 */
  @ExcelProperty("变动库存")
  @DecimalString(message = "变动库存小数格式不正确", label = "变动库存")
  private String changeStockQty;

  /** 暂存数量变更 */
  @ExcelProperty("暂存数量变更")
  @DecimalString(message = "暂存数量变更小数格式不正确", label = "暂存数量变更")
  private String changeStorageQty;

  /** 变动类型 */
  @ExcelProperty("变动类型")
  @Size(max = 10, message = "变动类型长度不能超过10")
  private String changeType;

  /** 待检待上架结存量 */
  @ExcelProperty("待检待上架结存量")
  @LongString(
    message = "待检待上架结存量数值格式不正确",
    label = "待检待上架结存量"
  )
  private String checkedAndSettled;

  /** 辅助数量 */
  @ExcelProperty("辅助数量")
  @DecimalString(message = "辅助数量小数格式不正确", label = "辅助数量")
  private String auxQty;

  /** 次品在途结存量 */
  @ExcelProperty("次品在途结存量")
  @LongString(
    message = "次品在途结存量数值格式不正确",
    label = "次品在途结存量"
  )
  private String defectiveGoodsInTransit;

  /** 可用锁定量 */
  @ExcelProperty("可用锁定量")
  @LongString(message = "可用锁定量数值格式不正确", label = "可用锁定量")
  private String defectiveLockAmount;

  /** 陈列数量 */
  @ExcelProperty("陈列数量")
  @DecimalString(message = "陈列数量小数格式不正确", label = "陈列数量")
  private String displayQty;

  /** 关联制单人 */
  @ExcelProperty("关联制单人")
  @Size(max = 50, message = "关联制单人长度不能超过50")
  private String formOperator;

  /** 变动源类型 */
  @ExcelProperty("变动源类型")
  @Size(max = 10, message = "变动源类型长度不能超过10")
  private String fromType;

  /** 次品在途量 */
  @ExcelProperty("次品在途量")
  @LongString(message = "次品在途量数值格式不正确", label = "次品在途量")
  private String goodsInTransit;
}
